type
Runtime validation and processing of JavaScript types
- Respects language nature and acknowledges its quirks
- Allows coercion in restricted forms (rejects clearly invalid input, normalizes permissible type deviations)
- No transpilation implied, written to work in all ECMAScript 3+ engines
Example usage
Bulletproof input arguments normalization and validation:
const ensureString = require('type/string/ensure')
, ensureDate = require('type/date/ensure')
, ensureNaturalNumber = require('type/natural-number/ensure')
, isObject = require('type/object/is');
module.exports = (path, options = { min: 0 }) {
path = ensureString(path, { errorMessage: "%v is not a path" });
if (!isObject(options)) options = {};
const min = ensureNaturalNumber(options.min, { default: 0 })
, max = ensureNaturalNumber(options.max, { isOptional: true })
, startTime = ensureDate(options.startTime, { isOptional: true });
};
Installation
npm install type
Utilities
Serves following kind of utilities:
*/coerce
Restricted coercion into primitive type. Returns coerced value or null
if value is not coercible per rules.
*/is
Object type/kind confirmation, returns either true
or false
.
*/ensure
Value validation. Returns input value (in primitive cases possibly coerced) or if value doesn't meet the constraints throws TypeError
.
Each */ensure
utility, accepts following options (eventually passed with second argument):
isOptional
- Makes null
or undefined
accepted as valid value. In such case instead of TypeError
being thrown, null
is returned.default
- A value to be returned if null
or undefined
is passed as an input value.errorMessage
- Custom error message (%v
can be used as a placeholder for input value)
Value
Value, any value that's neither null
nor undefined
.
value/is
Confirms whether passed argument is a value
const isValue = require("type/value/is");
isValue({});
isValue(null);
value/ensure
Ensures if given argument is a value. If it's a value it is returned back, if not TypeError
is thrown
const ensureValue = require("type/value/ensure");
const obj = {};
ensureValue(obj);
ensureValue(null);
Object
Object, any non-primitive value
object/is
Confirms if passed value is an object
const isObject = require("type/object/is");
isObject({});
isObject(true);
isObject(null);
object/ensure
If given argument is an object, it is returned back. Otherwise TypeError
is thrown.
const ensureObject = require("type/object/ensure");
const obj = {};
ensureObject(obj);
ensureString(null);
String
string primitive
string/coerce
Restricted string coercion. Returns string presentation for every value that follows below constraints
- is implicitly coercible to string
- is neither
null
nor undefined
- its
toString
method is not Object.prototype.toString
For all other values null
is returned
const coerceToString = require("type/string/coerce");
coerceToString(12);
coerceToString(undefined);
string/ensure
If given argument is a string coercible value (via string/coerce
) returns result string.
Otherwise TypeError
is thrown.
const ensureString = require("type/string/ensure");
ensureString(12);
ensureString(null);
Number
number primitive
number/coerce
Restricted number coercion. Returns number presentation for every value that follows below constraints
- is implicitly coercible to number
- is neither
null
nor undefined
- is not
NaN
and doesn't coerce to NaN
For all other values null
is returned
const coerceToNumber = require("type/number/coerce");
coerceToNumber("12");
coerceToNumber({});
coerceToNumber(null);
number/ensure
If given argument is a number coercible value (via number/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureNumber = require("type/number/ensure");
ensureNumber(12);
ensureNumber(null);
Finite Number
Finite number primitive
finite/coerce
Follows number/coerce
additionally rejecting Infinity
and -Infinity
values (null
is returned if given values coerces to them)
const coerceToFinite = require("type/finite/coerce");
coerceToFinite("12");
coerceToFinite(Infinity);
coerceToFinite(null);
finite/ensure
If given argument is a finite number coercible value (via finite/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureFinite = require("type/finite/ensure");
ensureFinite(12);
ensureFinite(null);
Integer Number
Integer number primitive
integer/coerce
Follows finite/coerce
additionally stripping decimal part from the number
const coerceToInteger = require("type/integer/coerce");
coerceToInteger("12.95");
coerceToInteger(Infinity);
coerceToInteger(null);
integer/ensure
If given argument is an integer coercible value (via integer/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureInteger = require("type/integer/ensure");
ensureInteger(12.93);
ensureInteger(null);
Safe Integer Number
Safe integer number primitive
safe-integer/coerce
Follows integer/coerce
but returns null
in place of values which are beyond Number.MIN_SAFE_INTEGER
and Number.MAX_SAFE_INTEGER
range.
const coerceToSafeInteger = require("type/safe-integer/coerce");
coerceToInteger("12.95");
coerceToInteger(9007199254740992);
coerceToInteger(null);
safe-integer/ensure
If given argument is a safe integer coercible value (via safe-integer/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureSafeInteger = require("type/safe-integer/ensure");
ensureSafeInteger(12.93);
ensureSafeInteger(9007199254740992);
Natural Number
Natural number primitive
natural-number/coerce
Follows integer/coerce
but returns null
for values below 0
const coerceToNaturalNumber = require("type/natural-number/coerce");
coerceToNaturalNumber("12.95");
coerceToNaturalNumber(-120);
coerceToNaturalNumber(null);
natural-number/ensure
If given argument is a natural number coercible value (via natural-number/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureNaturalNumber = require("type/natural-number/ensure");
ensureNaturalNumber(12.93);
ensureNaturalNumber(-230);
Plain Object
A plain object
- Inherits directly from
Object.prototype
or null
- Is not a constructor's
prototype
property
plain-object/is
Confirms if given object is a plain object
const isPlainObject = require("type/plain-object/is");
isPlainObject({});
isPlainObject(Object.create(null));
isPlainObject([]);
plain-object/ensure
If given argument is a plain object it is returned back. Otherwise TypeError
is thrown.
const ensurePlainObject = require("type/plain-object/ensure");
ensurePlainObject({});
ensureArray("foo");
Array
Array instance
array/is
Confirms if given object is a native array
const isArray = require("type/array/is");
isArray([]);
isArray({});
isArray("foo");
array/ensure
If given argument is an array, it is returned back. Otherwise TypeError
is thrown.
const ensureArray = require("type/array/ensure");
ensureArray(["foo"]);
ensureArray("foo");
Array Like
Array-like value (any value with length
property)
array-like/is
Restricted array-like confirmation. Returns true for every value that meets following contraints
- is an object (or with
allowString
option, a string) - is not a function
- Exposes
length
that meets array-length
constraints
const isArrayLike = require("type/array-like/is");
isArrayLike([]);
isArrayLike({});
isArrayLike({ length: 0 });
isArrayLike("foo");
isArrayLike("foo", { allowString: true });
array-like/ensure
If given argument is an array-like, it is returned back. Otherwise TypeError
is thrown.
const ensureArrayLike = require("type/array-like/ensure");
ensureArrayLike({ length: 0 });
ensureArrayLike("foo", { allowString: true });
ensureArrayLike({});
Array length
number primitive that conforms as valid array length
array-length/coerce
Follows safe-integer/coerce
but returns null
in place of values which are below 0
const coerceToArrayLength = require("type/safe-integer/coerce");
coerceToArrayLength("12.95");
coerceToArrayLength(9007199254740992);
coerceToArrayLength(null);
array-length/ensure
If given argument is an array length coercible value (via array-length/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureArrayLength = require("type/array-length/ensure");
ensureArrayLength(12.93);
ensureArrayLength(9007199254740992);
Iterable
Value which implements iterable protocol
iterable/is
Confirms if given object is an iterable and is not a string (unless allowString
option is passed)
const isIterable = require("type/iterable/is");
isIterable([]);
isIterable({});
isIterable("foo");
isIterable("foo", { allowString: true });
Supports also denyEmpty
option
isIterable([], { denyEmpty: true });
isIterable(["foo"], { denyEmpty: true });
iterable/ensure
If given argument is an iterable, it is returned back. Otherwise TypeError
is thrown.
const ensureIterable = require("type/iterable/ensure");
ensureIterable([]);
ensureIterable("foo", { allowString: true });
ensureIterable({});
Additionally items can be coreced with coerceItem
option. Note that in this case:
- A newly created array with coerced values is returned
- Validation crashes if any of the items is not coercible
ensureIterable(new Set(["foo", 12]));
ensureIterable(new Set(["foo", {}]));
Date
Date instance
date/is
Confirms if given object is a native date, and is not an Invalid Date
const isDate = require("type/date/is");
isDate(new Date());
isDate(new Date("Invalid date"));
isDate(Date.now());
isDate("foo");
date/ensure
If given argument is a date object, it is returned back. Otherwise TypeError
is thrown.
const ensureDate = require("type/date/ensure");
const date = new Date();
ensureDate(date);
ensureDate(123123);
Time value
number primitive which is a valid time value (as used internally in Date instances)
time-value/coerce
Follows integer/coerce
but returns null
in place of values which go beyond 100 000 0000 days from unix epoch
const coerceToTimeValue = require("type/time-value/coerce");
coerceToTimeValue(12312312);
coerceToTimeValue(Number.MAX_SAFE_INTEGER);
coerceToTimeValue("foo");
time-value/ensure
If given argument is a time value coercible value (via time-value/coerce
) returns result number.
Otherwise TypeError
is thrown.
const ensureTimeValue = require("type/time-value/ensure");
ensureTimeValue(12.93);
ensureTimeValue(Number.MAX_SAFE_INTEGER);
Function
Function instance
function/is
Confirms if given object is a native function
const isFunction = require("type/function/is");
isFunction(function () {});
isFunction(() => {});
isFunction(class {});
isFunction("foo");
function/ensure
If given argument is a function object, it is returned back. Otherwise TypeError
is thrown.
const ensureFunction = require("type/function/ensure");
const fn = function () {};
ensureFunction(fn);
ensureFunction(/foo/);
Plain Function
A Function instance that is not a Class
plain-function/is
Confirms if given object is a plain function
const isPlainFunction = require("type/plain-function/is");
isPlainFunction(function () {});
isPlainFunction(() => {});
isPlainFunction(class {});
isPlainFunction("foo");
plain-function/ensure
If given argument is a plain function object, it is returned back. Otherwise TypeError
is thrown.
const ensurePlainFunction = require("type/function/ensure");
const fn = function () {};
ensurePlainFunction(fn);
ensurePlainFunction(class {});
RegExp
RegExp instance
reg-exp/is
Confirms if given object is a native regular expression object
const isRegExp = require("type/reg-exp/is");
isRegExp(/foo/);
isRegExp({});
isRegExp("foo");
reg-exp/ensure
If given argument is a regular expression object, it is returned back. Otherwise TypeError
is thrown.
const ensureRegExp = require("type/reg-exp/ensure");
ensureRegExp(/foo/);
ensureRegExp("foo");
Promise
Promise instance
promise/is
Confirms if given object is a native promise
const isPromise = require("type/promise/is");
isPromise(Promise.resolve());
isPromise({ then: () => {} });
isPromise({});
promise/ensure
If given argument is a promise, it is returned back. Otherwise TypeError
is thrown.
const ensurePromise = require("type/promise/ensure");
const promise = Promise.resolve();
ensurePromise(promise);
eensurePromise({});
Thenable
Thenable object (an object with then
method)
thenable/is
Confirms if given object is a thenable
const isThenable = require("type/thenable/is");
isThenable(Promise.resolve());
isThenable({ then: () => {} });
isThenable({});
thenable/ensure
If given argument is a thenable object, it is returned back. Otherwise TypeError
is thrown.
const ensureThenable = require("type/thenable/ensure");
const promise = Promise.resolve();
ensureThenable(promise);
ensureThenable({});
Error
Error instance
error/is
Confirms if given object is a native error object
const isError = require("type/error/is");
isError(new Error());
isError({ message: "Fake error" });
error/ensure
If given argument is an error object, it is returned back. Otherwise TypeError
is thrown.
const ensureError = require("type/error/ensure");
const someError = new Error("Some error");
ensureError(someError);
ensureError({ message: "Fake error" });
Prototype
Some constructor's prototype
property
prototype/is
Confirms if given object serves as a prototype property
const isPrototype = require("type/prototype/is");
isPrototype({});
isPrototype(Object.prototype);
isPrototype(Array.prototype);
Tests
$ npm test